All files / src/app/recipes/[id] page.tsx

0% Statements 0/4
100% Branches 0/0
0% Functions 0/2
0% Lines 0/4

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35                                                                     
import type { Metadata } from 'next';
import { Suspense } from 'react';
import { getLocaleFromCookies } from '@/lib/locale/locale.server';
import { getMetadata } from '@/lib/seo/seo';
import RecipeDetailClient from './RecipeDetailClient';
 
interface RecipeDetailPageProps {
  params: Promise<{ id: string }>;
}
 
export async function generateMetadata(): Promise<Metadata> {
  const locale = await getLocaleFromCookies();
  return getMetadata(locale, 'seo', {
    titleKey: 'recipeDetailTitle',
    descriptionKey: 'recipeDetailDescription',
    fallbackTitle: 'Recipe Details',
    fallbackDescription:
      'View recipe details, ingredients and preparation steps.',
    keywordsKey: 'recipeDetailKeywords',
    fallbackKeywords: 'recipe, cooking, ingredients, meal',
    openGraph: { type: 'article' },
  });
}
 
export default async function RecipeDetailPage({
  params,
}: Readonly<RecipeDetailPageProps>) {
  const { id } = await params;
  return (
    <Suspense>
      <RecipeDetailClient recipeId={id} />
    </Suspense>
  );
}